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IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 

Applicants: O. IMMONEN 

Serial No. : Not yet assigned 
Filed: January 3, 2001 

For: SECURE SESSION SET UP BASED ON THE WIRELESS 

APPLICATION PROTOCOL 

Group: Not yet assigned 

Examiner: Not yet assigned 

PRELIMINARY AMENDMENT 

Assistant Commissioner for Patents January 3, 2001 

Washington, D.C. 20231 

Sir: 

Prior to examination, please amend the above -identified 
application as follows . 



IN THE CLAIMS 

Please amend the claims as follows: 

3. (Amended) A method according to claim 1 [or 2], 
further [and] comprising a step of re-establishing the 
connection by transmitting a request from the wireless 
communication apparatus to the data communication apparatus, 
said request comprising the calculated signature based on the 
chosen algorithm, the public key and the stored secret key, 
and upon reception of the request, the data communication 
apparatus calculates the master secret code based on the 
chosen algorithm, the signature received, and the private key, 



and, establish a secure connection to the wireless 
communication apparatus. 

4. (Amended) A method according to claim 1, [2 or 3,] 
and comprising a step of providing said separate unit in a 
smart card. 

7. (Amended) Wireless communication apparatus according 
to claim 5 [or 6] wherein the master secret code is stored on 
the separate unit. 

9. (Amended) Wireless communication apparatus according 
to [any one of claims] claim 5 [to 8] wherein the master 
secret code is generated on the separate unit . 

10. (Amended) Wireless communication apparatus according 
to [any one of claims] claim 5 [to 9] wherein the signature is 
generated on the separate unit . 

11. (Amended) Wireless communication apparatus according 
to claim [any one of claims] 5 [to 10] wherein the separate 
unit comprises a smart card. 

13 . (Amended) A smart card according to claims 11 [or 

12] . 
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14 . (Amended) A wireless communication apparatus 
according to claim [any one of claims] 5 [to 12] without [the] 
a smart card [of claim 13] . 

17. (Amended) A memory card according to claim 15 [or 
16] , comprising a secure database provided with at least one 
master secret code and/or at least one signature related to 
one or more data communication apparatus, in order to re- 
establish a secure connection to data communication apparatus. 

18. (Amended) A memory card according to claim 15, [16, 
or 17, is] provided on a smart card. 

21. (Amended) A system according to claim 19, [or 20,] 
said memory means is a smart card. 

Please add new claims 25-45 as follows: 

25. A method according to claim 2, further comprising a 
step of re-establishing the connection by transmitting a 
request from the wireless communication apparatus to the data 
communication apparatus, said request comprising the 
calculated signature based on the chosen algorithm, the public 
key and the stored secret key, and upon reception of the 
request, the data communication apparatus calculates the 
master secret code based on the chosen algorithm, the 
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signature received, and the private key, and, establish a 
secure connection to the wireless communication apparatus. 



26. A method according to claim 2, and comprising a step 
of providing said separate unit in a smart card. 



27. A method according to claim 3, and comprising a step 
of providing said separate unit in a smart card. 



28. Wireless communication apparatus according to claim 
6 wherein the master secret code is stored on the separate 
unit . 



29. Wireless communication apparatus according to claim 
6 wherein the master secret code is generated on the separate 
unit . 



30. Wireless communication apparatus according to claim 
7 wherein the master secret code is generated on the separate 
unit . 



31. Wireless communication apparatus according to claim 
8 wherein the master secret code is generated on the separate 
unit . 
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32. Wireless communication apparatus according to claim 
6 wherein the signature is generated on the separate unit. 



33. Wireless communication apparatus according to claim 

7 wherein the signature is generated on the separate unit. 

34. Wireless communication apparatus according to claim 

8 wherein the signature is generated on the separate unit. 

35. Wireless communication apparatus according to claim 

9 wherein the signature is generated on the separate unit. 

36. Wireless communication apparatus according to claim 

6 wherein the separate unit comprises a smart card. 

37. Wireless communication apparatus according to claim 

7 wherein the separate unit comprises a smart card. 

38 . Wireless communication apparatus according to claim 

8 wherein the separate unit comprises a smart card. 

39. Wireless communication apparatus according to claim 

9 wherein the separate unit comprises a smart card. 
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40. Wireless communication apparatus according to claim 
10 wherein the separate unit comprises a smart card. 

41. A smart card according to claims 12. 

42. A memory card according to claim 16, comprising a 
secure database provided with at least one master secret code 
and/or at least one signature related to one or more data 
communication apparatus, in order to re-establish a secure 
connection to data communication apparatus. 

43. A memory card according to claim 16, is provided on 
a smart card. 

44. A memory card according to claim 17, provided on a 
smart card. 

45. A system according to claim 20, said memory means is 
a smart card. - - 

REMARKS 

Entry of the above amendments prior to examination is 
respectfully requested. 

Please charge any shortage in fees due in connection with 
the filing of this paper, or credit any overpayment of fees, 
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to the deposit account of Antonelli, Terry, Stout & Kraus, 
LLP, Deposit Account No. 01-2135 (367.39437X00) . 

Respectfully submitted, 

ANTONELLI, TERRY, STOUT Sc KRAUS, LLP 




Carl I . Brurfdidge 
Registration No. 2 9,621 
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(703) 312-6600 
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Secure session set up based on the Wireless Application Protocol. 

5 

Technical Field of the Invention 

The Wireless Application Protocol (WAP) defines an industry-wide 
specification for developing applications that operate over wireless 
communication networks. The wireless market is growing very quickly, and 
10 reaching new customers and services. To enable operators and 
manufacturers to meet the challenges in advanced services, differentiation 
and fast/flexible service creation a set of protocols has been designed in 
transport, security, transaction, session and application layers. 

15 Background of the Invention 

WAP security functionality includes the Wireless Transport Layer Security 
(WAPWTLS) and application level security, accessible using Wireless Markup 
Language Script (WMLScript). For optimum security, some parts of the 
security functionality need to be performed by a tamper-resistant device, so 
20 that an attacker cannot retrieve sensitive data. Such data is especially the 
permanent private keys used in WTLS handshake with client authentication, 
and for making application level electronic signatures (such as confirming an 
application level transaction). In WTLS, also master keys (master secrets) are 
relatively long living - which could be several days - this is in order to^void 
25 frequent full handshakes which are quite heavy both computationally and due 
to relatively large data transfer. Master secrets are used as a source of 
entropy, to calculate MAC keys and message encryption keys which are used 
to secure a limited number of messages, depending on usage of WTLS. 
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US-A-5,307,41 1 describes the set up of a secure communication session 
between two communication units, such as phones or facsimile machines. 
The secure session is controlled by separate smart cards based verification 
units associated with a respective one of the communication units. These two 
5 verification units exchange random number, encrypt these numbers by using 
private keys, and return the encrypted random numbers to their origin. Then 
the encrypted random number is decrypted based on public keys, If the 
received numbers correspond to the transmitted numbers, the parties verify 
each other and the secure session may take place. However, this requires 

10 that both communication units are provided with a smart card reader, which is 
not a necessary requirement in a server, like e.g. an Internet server. Thus, 
this document is quite restricting for the user, since it requires that both 
parties have a smart card reader, and is less suitable for communication 
between a wireless communication apparatus and a data* communication 

15 apparatus. Also, every time a session is gbing to be established between the 
two communication apparatuses, an exchange of keys must be done. 

Also, US-A-5,371,794, by Sun Microsystems, discloses a way to providing a 
secure wireless communication link between a mobile nomadic device and a 

20 base computing unit. The mobile device sends a host certificate to the base 
along with a randomly chosen challenge value (CH1) and a list of supported 
shared key algorithms. The base sends random number (RN1) encrypted in 
the mobile's public key and an identifier for the chosen algorithm back to the 
mobile. The base saves the RN1 value and adds the CH1 value and the 

25 chosen algorithm to the mobile. The mobile verifies under the public key of the 
base the signature on the message. When the public key is verified, the 
mobile determines the value of RN1 by decrypting the public key under the 
private key of the mobile. The mobile then generates RN2 and a session key, 
and encrypts RN2 under the public key of the base to the base. The base 

30 verifies and decrypting the RN2, and determines the session key. Finally, the 
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mobile and the base can enter a data transfer phase using encrypted data 
which is decrypted using the session key which is RN1 + RN2. The values of 
RN1 and RN2 are always derived from the last key exchange, which may be 
from the initial connection setup or from the last key change message, 
5 whichever is more recent. This means that each time a data transfer is made, 
two new numbers are generated based on RN1 and RN2, which will make the 
data transfer quite slow. Thus, as in US-A-5,307,411, every time a session is 
going to be established between the two apparatuses, in this case the mobile 
nomadic device and the base computing unit, an exchange of keys must be 
r~ 10 done. 



Summary of the Invention 

The main object of the present invention is to establish a secure connection 
between a wireless communication apparatus and a data communication 
1 5 apparatus based on a wireless application protocol. 

Another object is to enable the user to re-establish a secure, connection at a 
later occasion, since establishing a secure connection is a heavy procedure 
both computationally .and^due to intensive data transfer. That is why, there is a 
20 need to use the mutually agreed master secret for a relatively long time. The 
problem is to store the master key in a secure way. Partly due to that problem, 
it is common practice to restrict the lifecycle of the master secret and the 
associated secure session to e.g., 24 hours, after which it is required to 
perform the heavy key establishment procedure anew. 

25 

The main object is achieved in accordance with the present invention by 
connecting a wireless communication apparatus, e.g. a cellular phone, to a 
separate unit, e.g. a smart card, a SIM (Subscriber Identity Module) card, etc., 
which may store sensitive data of a secure connection. This means that the 
30 wireless communication apparatus having some kind of contact means, for 
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example wireless (e.g. infra-red, radio frequency, etc.) or physical (i.e. an 
electrical contact), for receiving information from the separate unit, i.e. the unit 
is provided with memory means. The memory means comprises information 
to control an access of the wireless communication apparatus through a 
5 wireless communication network, e.g. a cellular phone network, connected to 
a data communication apparatus, e.g. a server, which supports a Wireless 
Application Protocol (WAP). 

One advantage of using a separate unit, when establishing a secure 
10 connection, is that it will be much easier to re-establish a connection to the 
data communication apparatus. Thus, it is possible to save information, e.g. 
signatures, secret keys, etc., in the memory means, and may be re-used in 
another secure connection. In order to avoid fraud, the re-use of a secure 
connection can be restricted for limited period of time. By saving this 
15 information in the memory means the second object will be achieved. 

Another advantage is that the user pays less when re-establishing a secure 
session, in case of the necessary information to re-establishing is saved. 

20 To establish a connection, the wireless communication apparatus connects to 
the separate unit, accessing the wireless communication network connected 
to said data communication apparatus. Then the wireless communication 
apparatus transmits a request to the data communication apparatus. "Phis 
request comprises information of which pre-defined algorithm(s) the wireless 

25 communication apparatus supports. When the data communication apparatus 
receives this request, it chooses at least one algorithm, associated with a 
public key and a private key, and transmits a message back to the wireless 
communication apparatus. This message comprises the public key and 
information about which algorithm the data communication apparatus has 

30 chosen. When the wireless communication apparatus receives the message, 



05-08-2000 j EP 009904720 



5 

comprising the public key, it will generate a master secret code, and 
calculates a signature based on the chosen algorithm, the public key and the 
master secret code. Thereafter, the wireless communication apparatus will 
transmit a respond to the data communication apparatus. This respond 
5 comprises the calculated signature. When the data communication apparatus 
receives the respond, comprising the signature, it will calculate the master 
secret code based on the chosen algorithm, the signature received, and the 
private key. Finally, the data communication apparatus will be able to 
establish a secure connection to the wireless communication apparatus. 

10 

In accordance with a first aspect of the present invention there is provided a 
method for establishing a secure connection between a wireless 
communication apparatus and a data communication apparatus based on a 
wireless application protocol, wherein said wireless communication apparatus 

15 has memory means including a separate unit comprising information to 
control the access of the wireless communication apparatus through a 
wireless communication network connected to said data communication 
apparatus, comprising the following steps: connecting said wireless 
communication apparatus to the separate unit, accessing the wireless 

20 communication network connected to said data communication apparatus 

the wireless communication apparatus ^transmits a request to the data 

i 

communication appar^atua-to establish a connection, said request comprising 
information of which pre-defined algorithm(s) the wireless communication 
apparatus supports, upon reception of said request, the data communication 

25 apparatus chooses at least one algorithm associated with a public and a 
private key, and transmits a message back to the wireless communication 
apparatus, said message comprising the public key and information about 
which algorithm the data communication apparatus has chosen, upon 
reception of the message, comprising the public key, the wireless 

30 communication apparatus generates a master secret code, and calculates a 
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signature based on ihe chosen algorithm, the public key and the master 
secret code, and transmits a response to the data communication apparatus, 
said response comprising the calculated signature, upon reception of the 
respond comprising the signature, the data communication apparatus 
5 calculates the master secret code based on the chosen algorithm, the 
signature received and the private key, and establish a secure connection to 
the wireless communication apparatus, and saving said master secret code 
on said memory means and in the data communication apparatus, in order to 
re-establish the connection at a later occasion. 

10 

According to a second aspect of the present invention there is provided 
wireless communication apparatus for establishing a secure connection to a 
data communication apparatus based on a wireless application protocol, said 
wireless communication apparatus comprising: communication means for 

1 5 establishing a connection to a wireless communication network connected to 
said data communication apparatus, memory means including a separate unit 
provided with information to control the access of the data communication 
apparatus through the wireless communication network, means for generating 
a master secret code control means arranged to use a pre-defined 

20 algorithm(s) for generating a signature based on said master secret code and 
a public key received from said data communication apparatus, for use when 
the wireless communication apparatus establishes a secure connection to the 
data communication apparatus, said memory means comprising a secure 
database for storing at least one master secret code and/or at least one 

25 signature related to one or more data communication apparatus, in order to 
re-establish a secure^eorinection to a data communication apparatus. 

According to a third aspect of the present invention there is provided memory 
card for establishing a secure connection between a wireless communication 
30 apparatus and a data communication apparatus based on a wireless 
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application protocol, arranged to be connected to contact means, provided on 
said wireless communication apparatus, for providing information from the 
memory card to the wireless communication apparatus upon establishing a 
secure session to a/ data communication apparatus, said information is 
5 arranged to control the access of the data communication apparatus through 
a wireless communication network, and to save a calculated master secret 
related to one or more data communication apparatus, in order to re-establish 
a secure connection to a data communication apparatus. 

10 Further advantages of the vane arrangement according to the present 
invention will be apparent from the dependent claims. 

Brief Description of the Drawing 

15 Fig. 1 schematically illustrates a preferred embodiment of a hand portable 
phone according to the invention. 

Fig. 2 schematically shows the essential parts of a telephone for 
communication with a cellular or cordless network. 

20 

Fig. 3 schematically shows how the secure session is set up between a client 
/phone and a server according to the invention. 

Fig. 4 illustrates the message structure for setting up a secure connection 
25 according to the invention. 

Detailed Description of Embodiments 
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Fig. 1 shows a preferred embodiment of a phone according to the invention, 
and it will be seen that the phone, which is generally designated by 1, 
comprises a user interface having a keypad 2, a display 3 T an on/off button 4, 
a speaker 5, and a microphone 6. The phone 1 according to the preferred 

5 embodiment is adapted for communication via a cellular network, but could 
have been designed for a cordless network as well. The keypad 2 has a first 
group 7 of keys as alphanumeric keys, by means of which the user can enter 
a telephone number, write a text message (SMS), write a name (associated 
with the phone number), etc. Each of the twelve alphanumeric keys 7 is 

10 provided with a figure "0-9" or a sign "#" or "*", respectively, in alpha mode 
each key is associated with a number of letters and special signs used in text 
editing. 

The keypad 2 additionally comprises two soft keys 8, two call handling keys 9, 
15 and a navigation key 10. 

The two soft keys 8 have a functionality corresponding to what is known from 
the phones Nokia 2110™, Nokia 8110™ and Nokia 3810™. The functionality of 
the soft key depends on the state of the phone and the navigation in the menu 
20 by using a navigation key. The present functionality of the soft keys 8 is 
shown in separate fields in the display 3 just above the keys 8. 

The two call handling keys 9 according to the preferred embodiment are u^ed 
for establishing a call or a conference call, terminating a call or rejecting an 
25 incoming call. 

The navigation key 10 is an up/down key and is placed centrally on the front 
surface of the phone between the display 3 and the group of alphanumeric 
keys 7. Hereby the user will be able to control this key with his thumb. This is 
30 the best site to place an input key requiring precise motor movements. Many 
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experienced phone users are used to one-hand handling. They place the 
phone in the hand between the finger tips and the palm of the hand. Hereby 
the thumb is free for inputting information. 

5 Fig. 2 schematically shows the most important parts of a preferred 
embodiment of the phone, said parts being essentia! to the understanding of 
the invention. The preferred embodiment of the phone of the invention is 
adapted for use in connection with the GSM network, but, of course, the 
invention may also be applied in connection with other phone networks, such 
10 as cellular networks and various forms of cordless phone systems or in dual 
band phones accessing sets of these systems/networks. The microphone 6 
records the user's speech, and the analog signals formed thereby are A/D 
converted in an A/D converter (not shown) before the speech is encoded in 
an audio part 14. The encoded speech signal is transferred to the controller 
15 18, which La. supports the GSM terminal software. The controller 18 also 
forms the interface to the peripheral units of the apparatus, including a RAM 
memory 17a and a Flash ROM memory 17b, a SIM card 16, the display 3 and 
the keypad 2 (as well as data, power supply, etc.). The controller 18 
communicates with the transmitter/receiver circuit 19. The audio part 14 
20 speech-decodes the signal, which is transferred from the controller 18 to the 
earpiece 5 via an D/A converter (not shown). 

The controller 18 is connected to the user interface. Thus, it is the controller 
18 which monitors the activity in the phone and controls the display 3 in 
25 response thereto. 

Therefore, it is the controller 18 which detects the occurrence of a state 
change event and changes the state of the phone and thus the display text. A 
state change event may be caused by the user when he activates the keypad 
30 including the navigation key 10, and this type of events is called entry events 
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or user events. However, the network communicating with the phone may 
also cause a state change event. This type of event and other events beyond 
the user's control are called non user events. Non user events comprise 
status change during call set-up, change in battery voltage, change in 
5 antenna conditions, message on reception of SMS, etc. 

An example of a tamper-resistant device is a smart card (SC). In the phone, it 
can be the Subscriber Identity Module (SIM) or an external smart card. 

10 The way which a phone and a smart card interact is specified as a command- 
response protocol. The goal of this protocol is to provide means for a WAP 
handset to utilize smart cards in performing WTLS and application level 
security functions. The functionality presented here is based on the 
requirement that sensitive data, especially keys, can be stored in the card, 

15 and all operations where these key are involved can be performed in the card. 
Different classes of the cards are introduced in order to define how widely the 
functionality is implemented. 

This specification is based on IS07816 series of standards on smart cards. In 
20 particular, it uses the 1S07816-8 standard (draft) [IS07816-8]. When this 
functionality is applied to GSM SIM there may be a need to extend also the 
related GSM specifications [GSM11.11], where applicable. 

According to the invention the smart card 16 is used to enhance security of 
25 the implementation of the Security Layer and certain functions of the 
Application Layer. The smart card 16 can be used for several purposes for 
WTLS. The major purpose of the smart card 16 is to perform cryptographic 
operations during the handshake, especially when the handshake is used for 
client authentication. Furthermore the memory of the smart card 16 is used for 
30 securing a master secret, a public key and other type of confidential material 
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during long-living WTLS sessions. Finally the memory of the smart card 16 is 
used for recording the level security of the sessions. According to the 
invention the WTLS support in a smart card 16 can be described with 
reference to the following three embodiments. 

5 

First embodiment. 

, t? 

According to this 'embodiment, the smart card 16 is used for storage of 
permanent, typically certified, private keys and for performing operations 
using these keys. The operations include signing operations (e.g., ECDSA or 
10 RSA) for client authentication when needed for the selected handshake 
scheme; key exchange operations using a fixed client key (e.g., ECDH key, in 
ECDH_ECDSA handshake). 

The smart card 16 is not required to perform the calculation of the master 
15 secret or operations using the master key. These calculations may 
advantageously be performed by the controller 18 of the phone. However, the 
smart card 16 may act as a persistent storage for WTLS secure session (and 
connection) data, including master secrets. In this case, master secrets would 
be calculated and used for key derivation in the volatile phone memory (the 
20 RAM 17a) but erased from there when not needed at that moment, e.g., when 
the user exits from secure WAP applications. Not storing session data 
persistently in phone 1 may improve security, e.g., in the case of a stolen 
phone 1. It also brings better usability in the case of changing the smart card 
1 6 from one phone 1 to another. 

25 

Additionally, for portability, the smart card 16 may store needed certificates. 
Storage of trusted root certificates (or public keys) has significance also from 
security point of view: they must not be altered - but they can be exposed 
. without danger. 

30 

AMENDED SHEET 



05-08-2000 



EP 009904720 



lo 

Note that when public key encryption based key exchange (e.g., RSA) is used 
according to the first embodiment of the invention, there is no advantage in 
doing public key encryption on the smart card 16 when the pre-master secret 
would anyway be returned to the phone 1 , for master secret calculation in the 
5 controller 18. 

When client authentication is not supported in WTLS, at the minimum, the 
smart card 1 6 only acts as a storage for session data. If client authentication 
is supported, the card would be able to perform a signing operation based on 
10 a private key (e.g./ ECDSA or RSA) stored in the card, or key agreement 
calculation (e.g., ECDtf ) based on a fixed key stored in the card. 

Second embodiment. 

According to the second embodiment, the smart card 16 is used as a tamper 
1 5 resistant device for all crypto-critical functionality: storage of all persistent keys 
and operations using these keys. Besides the operations performed according 
the first embodiment, the smart card 16 now also supports the 
calculation (ECDH key exchange) or generation (RSA key exchange) of the 
pre-master secret; calculation and storage of the master secret for each 
20 secure session; and derivation and output of key material (for MAC, 
encryption keys, IV, finished check), based on the master secret 

The phone 1 stores MAC and message encryption keys as long as they are 
currently needed. These keys have a limited lifetime which may be negotiated 
25 during the WTLS handshake - in the extreme case they are used for a single 
message only. The phone 1 has to delete the from its RAM memory 17a when 
the user exits from the secure WAP applications. These keys can always be 
derived anew from the master secret if needed. 
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An attacker who obtains a message encryption key can read as many 
messages as is agreed in the key refresh configuration (in the extreme case t 
a single message). An attacker who obtains a MAC key can impersonate the 
compromised party during as many messages as is agreed in the 
5 configuration (in the extreme case, a single message). 

Third embodiment. 

Certain specialized smart cards 16 may act as full-blown security engines for 
WTLS. This requires that the smart card 16 is equipped with its own 
10 processing unit and only uses the phone 1 as an interface to the cellular 
network during the secure session set up or the handshake procedure. 
Besides the operations according to the second embodiment, the smart card 
16 may store MAC and encryption keys for each secure connection; and 
perform MAC calculation/verification and encryption/decryption of messages. 

15 

Furthermore the smart card 16 may be responsible for the verification of 
certificates and the verification of digital signatures. 

Note that having message encryption in the smart card 16 does not 
20 necessarily bring any additional security because in any case the data is as 
plain text in the phone 1. The same is true for MAC calculation: the phone 1 
must be trusted to input and output data in a correct way. The only advantage 
here would be not having to take encryption keys out of the card 16. However, 
the keys have a limited lifetime which is negotiated during the WTLS 
25 handshake - in the extreme case they are used for single message only. 
According to the third embodiment, the smart card 16 will contain all 
algorithms so that they could be controlled by smart card issuers. 

Smartcard. 
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The term "smartcard" covers a card-like unit having some memory means in 
which some secret information identifying the card holder is stored. The 
memory means may be a magnet strip that may be read by a magnet reader, 
or it may be provided as discrete memory components as a ROM, EEPROM 
5 etc. When the user inserts the smart card in a more or less public apparatus 
he may become authorized to perform some operations such as banking 
operations. Presently the user of a GSM phone is identified by a so-called 
Subscriber Identity Module or a SIM card 16, and the structure of this type of 
smart card is defined in the GSM specification "Specification of the Subscriber 
10 Identity Module - Mobile Equipment (SIM - ME) interface", GSM 11.11 version 
5.5.0, published by European Telecommunications Standards Institute; ETSL 
The present type of smartcards will be able to support the first embodiment 
explained above. 

15 Gemplus has recently launched a smartcard, GemXpresso RAD, based on a 
32-bit chip from Texas Instruments using ARM7 RISC core technology. This 
32 bit RISC processor has a 32 kbyte of non volatile flash memory and 8 
kbyte of ROM. When the mechanical interface of the Gemplus card is adapted 
to fulfill the GSM specification this type of smartcard will be able to support the 

20 second and the third embodiment. 

Network. 

Fig. 3 schematically shows how the secure session, i.e. a secure connection, 
between a data communication apparatus and a wireless communication 

25 apparatus, e.g. a cellular phone 1. Basically the WAP content and 
applications are specified in a set of well-known content formats based on the 
familiar WWW content formats. Content is transported using a set of standard 
communication protocols based on the WWW communication protocols. A 
browser in the phone 1 co-ordinates the user interface and is 

30 analogous to a standard web browser. 
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The wireless communication apparatus 1 is a client 1 who wants to establish 
a secure connection to a server 20,30,40, which is the data communication 
apparatus 20,20,30. The client is provided in an environment which make it 

5 possible to reach a wide variety of different wireless platforms, e.g. world wide 
web (WWW). The environment provided may be referred to as Wireless 
Application Environment (WAE). This means that the client 1 may be 
supported by some kind of browser, e.g. a micro-browser, to access the 
different services connected to the server. In order to access these services 

10 the browser may comprise following functionalities: 

* Wireless Markup Language (WML) - a lightweight markup language, similar 
to HTML, but optimised for use in hand-held mobile terminals; 

• WMLScript - a lightweight scripting language, similar to JavaScript™; 

- Wireless Telephony Application (WTA, WTAI) ~ telephony services and 
15 programming interfaces; and 

- Content Formats - a set of well-defined data formats, including images, 
phone book records and calendar information. 

The server 20 is using a wireless application protocol, and may comprise a 
20 gateway 30 and an origin server 40. The gateway 30 is also a server, which 
may identify and encrypt/decrypt information between the client 1 and the 
origin server 40. This means that the gateway is provided with encoders and 
decoders (not shown). Also, the server 20 comprises different algorithms to 
make the encryption/decryption. The encryption/decryption itself m^V be 
25 performed by well-known methods, e.g. RSA, Diffie-Hellman, etc. The origin 
server 40 comprises different scripts to support WAP and data to be accessed 
by the client This data may be all kind of information, e.g. weather reports, 
news, information from stock markets, etc. 
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In order to access the server 20, from the client 1, the server has to be 
connected to a wireless communication network 50, e.g. a cellular phone 
network. Therefore, in accordance with the present invention, the client is 
provided with contact means (not shown) for receiving information from a 

5 separate unit (not shown) provided with memory means. This separate unit 
may be a smart card, subscriber identity module (SIM), or the like. The 
memory means may be a random access memory (RAM), read only memory 
(ROM), or the like. Further, the memory means comprises information to 
control the access of the server 20 through the wireless communication 

10 network 50. 

To establish a secure connection, the client 1 connects to the separate unit, 
accessing the wireless communication network 50 connected to the server 20. 
Then the client 1 transmits an encrypted request 60 through the gateway 30. 
15 This encrypted request 60 comprises information of which pre-defined 
algorithm(s) the client 1 supports. When the gateway 30 receives this 
encrypted request 60, it sends 70 the encrypted request to the origin server 
40. The origin server 40 chooses at least one algorithm, associated with a 
public key and a private key, and transmits a message 80 back to the 
20 gateway 30. The gateway encrypts the message and send it 90 to the client 1 . 
This message 90 comprises the public key and information about which 
algorithm the server 20 has chosen. When the client 1 receives the encrypted 
message 90, comprising the public key, it will generate a master secret code, 
and calculates a signature based on the chosen algorithm, the public key and 
25 the master secret code. Thereafter, the client 1 will transmit an encrypted 
respond 65 to the gateway 30. This encrypted respond 65 comprises the 
calculated signature. When the gateway 30 receives the encrypted respond 
80, comprising the signature, it will decrypt the respond 75 and send it to the 
origin server 40. The origin server will calculate the master secret code based 
30 on the chosen algorithm, the signature received, and the private key. Finally, 
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the origin server 40 sends a final message 85 to the client through the 
gateway 30. If the origin server 40 has accepted the clients 1 request 60, the 
server will be able to establish a secure connection between the origin server 
40 and the client 1, else the connection will be terminated. 

5 

Setting up a secure connection. 

Fig. 4 illustrates the message structure for setting up a secure connection 
according to the invention. 

10 The cryptographic parameters of the secure session are produced by the 
WTLS Handshake Protocol, which operates on top of the WTLS Record 
Layer. When a WTLS client and server first start communicating, they agree 
on a protocol version, select cryptographic algorithms, optionally authenticate 
each other, and use public-key encryption techniques to generate a shared 

1 5 secret. 

The WTLS Handshake Protocol is described Wireless Transport Layer 
Security Specification dated 30. April 1998 and is a part of the Wireless 
Application Protocol. 

20 

The WTLS Handshake Protocol involves the following sequence of steps. 
When the a WAP session has been set between the phone 1 (the client) and 
the server 20 (e.g. a bank), and the client (phone 1) wants to establish a 
secure connection he sends a client hello message 100 as his first message. 

25 This message includes a key exchange list that contains the cryptographic 
key exchange algorithms supported by the client in decreasing order of 
preference. In addition, each entry defines the certificate or public key the 
client wishes to use. The server will select one or, if no acceptable choices 
are presented, return a handshake failure alert and close the secure 

30 connection. 
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In response to the client hello message 100 the server 20 will send a server 
hello message 101 when it was able to find an acceptable set of algorithms. If 
it cannot find such a match, it must respond with a handshake_failure alert. 
5 The server hello message 101 will identify the session and set up the 
parameters need for the session. 

The server 20 will furthermore transmit a server certificate message 102. The 
server certificate message 102 will always immediately follow the server hello 

10 message 101 , and the purpose of this server certificate message 102 identify 
the cryptation algorithm selected by the server from the key exchange list 
included in the client hello message 100. The server certificate message 102 
will include a so-called certificate carrying a public key for the selected 
encryption algorithm. The server certificate message 102 includes information 

1 5 about issuer of the certificate, the beginning and the end of the validity period, 
and parameters relevant or the public key. The server controls the validity 
period and when the granted validity period is expired the client has to renew 
the secure connection. The length of the validity period will typically be in the 
level of a week or more. The maximum number of session will also have to be 

20 defined. 



A Server Key Exchange Message 103 will be send as a third message 
immediately after the server certificate message 102. The server key 

25 exchange message 103 is optionally and will be sent by the server 20 only 
when the server certificate message102 does not contain enough data to 
allow the client 1 to exchange a pre-master secret. This message 103 
conveys cryptographic information to allow the client to communicate the pre- 
master secret: either an RSA public key to encrypt a secret with, or Elliptic 

30 Curve Diffie-Hellman parameters with which the client can complete a key 
exchange (with the result being the pre-master secret). As additional Key 
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Exchange Suites are defined for WTLS which include new key exchange 
algorithms, the server key exchange message will be sent if and only if the 
certificate type associated with the key exchange algorithm does not provide 
enough information for the client to exchange a pre-master secret. 

5 

Also a forth message - a Server Certificate message 104 - is optionally. This 
message 104 requests a certificate from the client, if appropriate for the 
selected cipher suite. This message will immediately follow the Server 
Certificate message 102 and Server Key Exchange message 103. 

10 

In order to inform the client that the server has ended of the Server Hello 
session, it transmits a Server Hello Done message 105. After sending this 
message 105 the server 20 will wait for a client response. This message 
indicates that the server 20 has send messages to support the key exchange, 
1 5 and that the client 20 can proceed with its phase of the key exchange. 

Upon receipt of the server hello done message the client should verify that the 
server provided a valid certificate if required and check that the server hello 
parameters are acceptable. 

20 If the server 20 asks for an Client Certificate message 107, the client 1 has to 
transmit such a after receiving a Server Hello Done message 105. This 
message is only sent if the server 20 requests a certificate. If no suitable 
certificate is available, the client must send a certificate message containing 
no certificates. If client authentication is required by the server for the 

25 handshake to continue, it may respond with a fatal handshake_failure alert. 
Client certificates are sent using the Certificate structure defined previously for 
server certificates. 

Now the phone 1 or the client starts to calculate a 20 byte random number to 
30 be used as a Master Secret 106 for the secure sessions. The master secret 
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106 is used to derive key material needed for Message Authentication Code 
(MAC) keys and data encryption keys. MAC and data encryption provide data 
integrity and privacy between communicating parties. A public key based key 
establishment is a heavy procedure both computationally and due to intensive 
5 data transfer. That is why, there is a need to use the mutually agreed master 
secret 1 06 for a relatively long time. 

The processor or the controller 18 of the phone 1 calculates the master 
secret. A smart card, e.g. the SIM card16, which can be regarded as a tamper 

10 resistant device, is used for storage of the sensitive data of the secure 
session, and performing operations using that sensitive data, so that this data 
never leaves the card. In practice the secure information will be transferred 
from the SIM card 16 to the working RAM 17a of the processor 18 but these 
information will be overwritten when no session is ongoing or when the phone 

15 1 is switched off. 

According to the first embodiment of the invention the controller 18 performs 
the operations needed for the key establishment, e.g., Diffie-Hellrnan 
calculation or RSA encryption and complementary calculations. Then the 

20 controller 18 persistently stores the resulting secret key (master secret 106) in 
the SIM card 16. Then the controller 18 performs the key derivation based on 
the master secret 106 and additional data (e.g., seed), producing key material 
for MAC calculation and encryption. The key derivation function is secifrity 
protocol specific. It is typically based on some secure hash function, e.g., 

25 SHA-1. 

Preferably the SIM card 16 is provided as a smart card having its own 
processor, whereby both the operations needed for performing the key 
establishment and the key derivation based on the master secret may be 
30 performed inside the smart card. Then the master secret, and data used to 
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calculate it, would never have to leave smart card. So, the secure session 
associated with the master secret can be used during a long period 

A Client Key Exchange Message 108 will immediately follow the client 
5 certificate message 107, if it is sent. Otherwise it will be the first message sent 
by the client 1 after it receives the Server Hello Done message 105. With this 
message 108, a pre-master secret is set, either through direct transmission of 
the RSA-encrypted secret, or by the transmission of EC Diffie-Heilman public 
key which will allow each side to agree upon the same pre-master secret 

10 

Then the Master Secret 106 is encrypted by using the public key from the 
server's certificate and the agreed RSA algorithm. The result is send to the 
server 20 in an encrypted master secret message 109. 

15 A Certificate Verify message 110 is used to provide explicit verification of a 
client certificate. This message is only sent by the client following a client 
certificate Message 107 that has signing capability (i.e., RSA certificates). 

Both ends has to send finished messages 111 and 112 at the end of the 
20 handshake to verify that the key exchange and authentication processes were 
successful. 

The finished messages 111 and 112 is the first messages protected with the 
just-negotiated algorithms, keys, and secrets. Recipients of fintehed 
25 messages must verify that the contents are correct. Once a side has sent its 
Finished message and received and validated the Finished message from its 
peer, it may begin to send and receive application data 113 over the secure 
connection. It is a critical or fatal error if a finished message is not preceded 
by a change cipher spec message at the appropriate point in the handshake. 

30 
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The value handshake_messages includes all handshake messages starting at 
client hello up to, but not including, this finished message. The 
handshake_messages for the finished message sent by the client will be 
different from that for the finished message sent by the server, because the 
5 one which is sent second will include the prior one. 

As long as a secure connection is valid application data session 113 may be 
initiated just by using Client Hello messages 100 and Server Hello messages 
101. 



10 





Acronyms. 






APDU 


Application Protocol Data Unit 




API 


Application Programming Interface 




CA 


Certification Authority 


15 


CBC 


Cipher Block Chaining 




DF 


Dedicated File 




DH 


Diffie-Hellman 




EC 


Elliptic Curve 




ECC 


Elliptic Curve Cryptography 


20 


ECDH 


Elliptic Curve Diffie-Hellman 




ECDSA 


Elliptic Curve Digital Signature Algorithm 




EF 


Elementary File 




GSM 


Global System for Mobile Communication 




IV 


Initialization Vector 


25 


MAC 


Message Authentication Code 




ME 


Management Entity 




OS! 


Open System Interconnection 




PDU 


Protocol Data Unit 




PRF 


Pseudo-Random Function 


30 


SAP 


Service Access Point 
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SDU Service Data Unit 

SHA-1 Secure Hash Algorithm 

SIM Subscriber Identity Module 

SMS Short Message Service 

5 SSL Secure Sockets Layer 

TLS Transport Layer Security 

WAP Wireless Application Protocol 

WML * Wireless Markup Language 
WMLScript Wireless Markup LanguageScript 

10 WDP Wireless Datagram Protocol 

WSP Wireless Session Protocol 

WTLS Wireless Transport Layer Security 

WTP Wireless Transaction Protocol 



15 The list above includes the acronyms used in the present text. Detailed 
discussion and explanation of the acronyms may be found in the technical 
specifications defining the Wireless Application Protocol on the Internet 
homepage for WAPFORUM, http://www.wapforum.org/. 
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CLAIMS 

1. Method for establishing a secure connection between a wireless 
5 communication apparatus and a data communication apparatus based on a 
wireless application protocol, wherein said wireless communication apparatus 
has memory means including a separate unit comprising information to 
control the access of the wireless communication apparatus through a 
wireless communication network connected to said data communication 
1 0 apparatus, comprising the following steps: 

connecting said wireless communication apparatus to the separate unit, 
accessing the wireless communication network connected to said data 
communication apparatus 

the wireless communication apparatus -transmits a request to the data 
15 communication apparatus to establish a connection, said request comprising 
information of which pre-defined afgorithm(s) the wireless communication 
apparatus supports, 

upon reception of said request, the data communication apparatus chooses at 
least one algorithm associated with a public and a private key, and transmits a 
20 message back to the wireless communication apparatus, said message 
comprising the public key and information about which algorithm the data 
communication apparatus has chosen, 

upon reception of the message, comprising the public key, the wireless 
communication apparatus generates a master secret code, and calculates a 
25 signature based on the chosen algorithm, the public key and the master 
secret code, and transmits a response to the data communication apparatus, 
said response comprising the calculated signature, 

upon reception of the respond comprising the signature, the data 
communication apparatus calculates the master secret code based on the 
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chosen algorithm, the signature received and the private key, and establish a 
secure connection to the wireless communication apparatus, and 
saving said master secret code on said memory means and in the data 
communication apparatus, in order to re-establish the connection at a later 
5 occasion. 

2. A method according to claim 1, and comprising a step of saving said 
- master secret under a pre-defined time. 

10 3. A method according to claim 1 or 2, and comprising a step of re- 
establishing the connection by 

transmitting a request from the wireless communication apparatus to the data 
communication apparatus, said request comprising the calculated signature 
based on the chosen algorithm, the public key and the stored secret key, and 
15 upon reception of the request, the data communication apparatus calculates 
the master secret code based on the chosen algorithm, the signature 
received, and the .private key, and, establish a secure connection to the 
wireless communication apparatus. 

20 4. A method according to claim 1, 2, or 3, and comprising a step of 
providing said separate unit in a smart card. 

5. Wireless communication apparatus for establishing a secure 
connection to a data communication apparatus based on a wireless 

25 application protocol, said wireless communication apparatus comprising: 

communication means for establishing a connection to a wireless 
communication network connected to said data communication apparatus, 
memory means including a separate unit provided with information to control 
the access of the data communication apparatus through the wireless 

30 communication network, 
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means for generating a master secret code 

control means arranged to use a pre-defined algorithm(s) for generating a 
signature based on said master secret code and a public key received from 
said data communication apparatus, for use when the wireless 
5 communication apparatus establishes a secure connection to the data 
communication apparatus, 

said memory means comprising a secure database for storing at least one 
master secret code and/or at least one signature related to one or more data 
communication apparatus, in order to re-establish a secure connection to a 
10 data communication apparatus. 

6. A wireless communication apparatus according to claim 5, having its 
memory means exchangeable. 

15 7. Wireless communication apparatus according to claim 5 or 6 wherein 
the master secret code is stored on the separate unit. 

8. Wireless communication apparatus according to any one of claims 5 to 

7 wherein the signature is stored on the separate unit. 
20 ■ 

9. Wireless communication apparatus according to any one of claims 5 to 

-J; Mr'* 

8 wherein the mastersecret code is generated on the separate unit. 

1 0. Wireless communication apparatus according to any one of claims 5 to 
25 9 wherein the signature is generated on the separate unit. 

1 1 . Wireless communication apparatus according to any one of claims 5 to 
10 wherein the separate unit comprises a smart card. 
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12. An apparatus according to claim 11 wherein the smart card is a 
subscriber identity module. 

13. A smart card according to claims 11 or 12. 

5 

14. A wireless communication apparatus according to any one of claims 5 
to 1 2 without the smart card of claim 1 3. 

15. Memory card for establishing a secure connection between a wireless 
10 communication apparatus and a data communication apparatus based on a 

wireless application protocol, arranged to be connected to contact means, 
provided on said wireless communication apparatus, for providing information 
from the memory card to the wireless communication apparatus upon 
establishing a secure session to a data communication apparatus, said 
15 information is arranged to control the access of the data communication 
apparatus through a wireless communication network, and to save a 
calculated master secret related to one or more data communication 
apparatus, in order to re-establish a secure connection to a data 
communication apparatus. 

20 

16. A memory card according to claim 15, further comprising encryption 
means for encrypting the master secret, which is to be used as a signature for 
the wireless communication apparatus when it is establishing a secure 
connection. f . 

25 / 

17. A memory card according to claim 15 or 16, comprising a secure 
database provided with at least one master secret code and/or at least one 
signature related to one or more data communication apparatus, in order to 
re-establish a secure connection to a data communication apparatus. 

30 
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18. A memory card according to claim 15, 16, or 17, is provided on a 
smart card. . ' > 

19. System for establishing a secure connection when using a wireless 
5 application protocol, comprising: 

a data communication apparatus based on the wireless application protocol, 
a wireless communication network, connected to said data communication 
apparatus, 

a wireless communication apparatus having memory means including a 
10 separate unit comprising information to control the access of the wireless 
communication apparatus through the wireless communication network, 
wherein 

the wireless communication apparatus is arranged to transmit a request to the 
data communication apparatus to establish a connection, said request 
15 comprising information of which pre-defined algorithm(s) the wireless 
communication apparatus supports, 

upon reception of said request, the data communication apparatus is 
. arranged to choose at least one algorithm, associated with a public key and a 
private key, and to transmit a message back to the wireless communication 

20 apparatus, said message comprising the public key and information about 
which algorithm the data communication apparatus will choose, 
upon reception of said message, comprising the public key, the wireless 
communication apparatus is arranged to generate a master secret code, to 
calculate a signature based on the chosen algorithm, the public key and the 

25 master secret code, and to transmit a respond to the data communication 
apparatus, said respond comprising the calculated signature, 
upon reception of the respond comprising . the signature, the data 
communication apparatuses arranged to calculate the master secret code 
based on the chosen algorithm, the signature received, and the private key, 
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"and, thus establish a secure connection to the wireless communication 
apparatus, and 

said memory means being arranged to save said master secret code, in order 
to re-establish the connection at a later occasion. 

5 

20. A system according to claim 19, said master secret is arranged to be 
saved under a pre-defined time. 

21. A system according to claim 19, or 20, said memory means is a smart 
10 card. 

22. A wireless communication apparatus for establishing a secure 
connection to a data communication apparatus through a wireless network 
based on a wireless application protocol, said wireless communication 

15 apparatus comprising: 

means for establishing a connection with the data communication apparatus 
through the wireless network 

means for retrieving access information including which of a set of pre-define 
algorithms is supported, for transmission to the data communication 
20 apparatus; 

means for processing information including a public key and the selection of 
one of the supported algorithms received from the data communication 
apparatus for storage; 

means for retrieving a signature based on a generated master secret code 
25 and the public key received from the data communication apparatus; and 

means for utilising the signature and/or the master secret key during 
communication with the data communication apparatus in order to re- 
establish a secure connection. 
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23. A memory card for establishing a secure connection between a 
wireless communication apparatus and a data communication apparatus 
based on a wireless application protocol comprising contact means for % 
cooperation with the wireless communication apparatus 

5 a memory for storing a master secret code associated with the data 
communication apparatus and responsive to a request from the wireless 
communication apparatus to provide such code for utilisation of the master 
secret key during communication with the data communication apparatus in 
order to re-establish a secure connection. * 

10 ; / v 

24. Wireless communication apparatus for establishing a secure 
connection to a data communication apparatus based on a wireless 
application protocol, said wireless communication apparatus comprising: 
communication means for establishing a connection to a wireless 

15 communication network connected to said data communication apparatus, 

memory means provided with information to control the access of the data 
communication apparatus through the wireless communication network upon 
establishing a secure session to a data communication apparatus, 
reading means for reading information received from the data communication 

20 apparatus and the information provided on said memory means, 
means for generating a master secret code, 

control means arranged to use a pre-defined algorithm(s) for generating a 
signature based on said master secret code and a public key received from 
said data communication apparatus, which is to be used when the wireless 
25 communication apparatus is going to establish a secure connection to the 
data communication apparatus, and 

said reading means comprising a secure database provided with at least one 
master secret code and/or at least one signature 1 related to one or more data 
communication apparatus, in order to re-establish a secure connection to a 
30 data communication apparatus. 
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